package com.sky.mapper;

import com.sky.annotation.AutoFill;
import com.sky.entity.User;
import com.sky.enumeration.OperationType;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Options;
import org.apache.ibatis.annotations.Select;
import org.springframework.beans.factory.annotation.Autowired;

import java.time.LocalDateTime;

@Mapper
public interface UserMapper {
    @Select("select  * from user where openid = #{openid}")
    User getByOpenid(String openid);

    @AutoFill(OperationType.INSERT)
    @Options(useGeneratedKeys = true, keyProperty = "id")
    @Insert("insert into user(openid,name,phone,sex,id_number,avatar,create_time) values(#{openid},#{name},#{phone},#{sex},#{idNumber},#{avatar},#{createTime})")
    void save(User user);
    @Select("select count(*) from user where create_time between #{begin} and #{end}")
    Integer countuser(LocalDateTime begin, LocalDateTime end);
}
